<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>jsx语法规则</title>
</head>
<style>
  .title {
    background: orange;
  }
</style>
<body>
  <!-- 容器 -->
  <div id="test"></div>

  <script crossorigin src="https://unpkg.com/react@16/umd/react.development.js"></script>
  <script crossorigin src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script>
  <script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>

  <script type="text/babel">
    let myId = 'haH'
    let myData = 'haData'
    const VDom = (
      <div>
        <h1 className='title' id={myId.toLowerCase()}>      
          <span style={{ color: 'red', fontSize: '19px' }}>{myData.toLowerCase()}</span>
        </h1>
        <input type="text" />  
        <good>111</good>  
        <Good>222</Good>
      </div>
    )       /* toLowerCase可以把大写转为小写 */


    ReactDOM.render(VDom, document.getElementById('test'))

    // jsx的语法规则
      // 1、定义虚拟dom时，不要写引号
      // 2、标签中混入js表达式时要用{}
      // 3、样式的类名指定不要用class，要用className
      // 4、内联样式，要用style={{ key: value }}的形式去写
      // 5、虚拟dom必须只有一个根标签
      // 6、标签必须闭合
      // 7、标签首字母
          // (1)若小写字母开头，则将该标签转为html中同名元素，若html中无同名元素，则报错
          // (2)若大写字母开头，react就去渲染对应的组件，若组件没有定义，则报错
     
  </script>
</body>
</html>